In the Claims: 



Please amend claims 12, 36, 45, 47, 50, 52, 53, 56, 59 and 60 as indicated below. 
1 . (Original) A peer computing system comprising: 

a plurality of peer nodes operable to couple to a network, wherein each of the 
plurality of peer nodes comprises one or more network interfaces, wherein 
each network interface is configured to communicate over the network in 
accordance with at least one of one or more network transport protocols; 

wherein the plurality of peer nodes is configured to implement a peer-to-peer 
environment on the network according to a peer-to-peer platform 
comprising one or more peer-to-peer platform protocols for enabling the 
plurality of peer nodes to discover each other, communicate with each 
other, and share content in the peer-to-peer environment; 

wherein one of the plurality of peer nodes is configured to: 

establish a communications channel between a network interface of the 
peer node and a network interface of another of the plurality of 
peer nodes; 

transmit messages to the other peer node over the communications 
channel; 

receive acknowledgement that one or more of the transmitted messages 
have been received by the other peer node; and 

retransmit messages not acknowledged as received by the other peer node 
to the other peer node on the communications channel 
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2. (Original) The peer computing system as recited in claim 1, wherein, to 
transmit messages to the other peer node over the communications channel, the peer node 
is further configured to: 

generate the messages; 

buffer the messages, and after a window of N messages has been buffered, 
transmit the N messages to the other peer node over the communications 
channel, wherein N is an integer greater than one. 

3. (Original) The peer computing system as recited in claim 2, wherein the other 
peer node is configured to receive the transmitted messages, and after receiving M 
messages, transmit the acknowledgement to the peer node indicating that the M messages 
have been received, wherein M is a positive integer less than or equal to N. 

4. (Original) The peer computing system as recited in claim 3, wherein N is a 
positive even integer, and wherein M is equal to N / 2. 

5. (Original) The peer computing system as recited in claim 3, wherein M is less 

than N. 

6. (Original) The peer computing system as recited in claim 5, wherein, to 
receive acknowledgement that one or more of the transmitted messages have been 
received by the other peer node, the peer node is further configured to receive the 
acknowledgement indicating that the M messages have been received, and wherein the 
peer node is further configured to: 

shift the window in the buffer by M messages; and 
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transmit the messages in the shifted window to the other peer node over the 
communications channel. 

7. (Original) The peer computing system as recited in claim 6, wherein the 
shifted window includes one or more messages previously transmitted to the other peer 
node and one or more messages not previously transmitted to the other peer node. 

8. (Original) The peer computing system as recited in claim 2, wherein each of 
the messages includes a sequence number for use in ordering the received messages on 
the other peer node, and wherein the other peer node is configured to: 

receive the transmitted messages; and 

after receiving the first M messages in the sequence of N transmitted messages as 
indicated by the sequence numbers, transmit the acknowledgement to the 
peer node indicating that the first M messages have been received, 
wherein M is a positive integer less than N. 

9. (Original) The peer computing system as recited in claim 2, wherein each of 
the messages includes a sequence number for use in ordering the received messages on 
the other peer node, and wherein the other peer node is configured to: 

continue receiving the transmitted messages until the first M messages in the 
sequence of N transmitted messages as indicated by the sequence numbers 
are received or a timeout limit from the time of initial receipt of one of the 
sequence of N transmitted messages is exceeded, wherein M is a positive 
integer less than N; 

if the first M messages in the sequence of N transmitted messages as indicated by 
the sequence numbers are received, transmit the acknowledgement to the 
peer node indicating that a count of messages received in continuous 
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sequence from a first message in the sequence of N transmitted messages 
is M; and 

if the timeout limit is exceeded before the first M messages in the sequence of N 
transmitted messages as indicated by the sequence numbers are received, 
transmit the acknowledgement to the peer node indicating the count of 
messages received in continuous sequence from the first message in the 
sequence of N transmitted messages, wherein the count of messages 
received in continuous sequence is less than M. 

10. (Original) The peer computing system as recited in claim 9, wherein, to 
receive acknowledgement that one or more of the transmitted messages have been 
received by the other peer node, the peer node is further configured to receive the 
acknowledgement indicating that the messages have been received, and wherein the peer 
node is further configured to: 

shift the window in the buffer by the count of messages received in continuous 
sequence; and 

transmit the messages in the shifted window to the other peer node over the 
communications channel. 

11. (Original) The peer computing system as recited in claim 1, wherein each of 
the messages includes a sequence number for use in ordering the received messages on 
the other peer node. 

12. (Currently amended) The peer computing system as recited in claim [[1]] 3, 
wherein the peer node and the other peer node are further configured to: 

monitor reception and retransmission of the messages to determine reliability of 
the communications channel on the network; and 
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adjust the values of M and N according to said reliability of the communications 
channel. 

13. (Original) The peer computing system as recited in claim 12, wherein, to 
adjust the values, of M and N, the peer node and the other peer node are further 
configured to lower the values of M and N if said reliability of the communications 
channel is poor. 

14. (Original) The peer computing system as recited in claim 12, wherein, to 
adjust the values of M and N, the peer node and the other peer node are further 
configured to raise the values of M and N if said reliability of the communications 
channel is good. 

15. (Original) The peer computing system as recited in claim 1, wherein the other 
peer node is configured to: 

transmit other messages to the peer node over the communications channel; 

receive acknowledgement that one or more of the transmitted other messages 
have been received by the peer node; and 

retransmit messages not acknowledged as received by the peer node to the peer 
node on the communications channel. 

16. (Original) The peer computing system as recited in claim 1, wherein the peer 
node comprises an instance of a pipe service executable within the peer node to establish 
the communications channel, transmit the messages to the other peer node, receive the 
acknowledgement, and retransmit the messages not acknowledged as received. 
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17. (Original) The peer computing system as recited in claim 16, wherein the 
other peer node comprises another instance of the pipe service executable within the 
other peer node to receive the transmitted messages and transmit the acknowledgement to 
the peer node. 

18. (Original) The peer computing system as recited in claim 1, wherein the 
communications channel passes through one or more relay peers, wherein the one or 
more relay peers are configured to receive the transmitted messages from the peer node 
and forward the messages to the other peer node. 

19. (Original) The peer computing system as recited in claim 1, wherein the 
communications channel passes through one or more firewalls. 

20. (Original) The peer computing system as recited in claim 1, wherein the 
communications channel passes through one or more Network Address Translation 
(NAT) gateways. 

21. (Original) The peer computing system as recited in claim 1, wherein one or 
more other of the plurality of peer nodes are configured to connect to the communications 
channel, wherein the peer node is further configured to: 

transmit messages to the one or more other peer nodes over the communications 
channel; 

receive acknowledgements that one or more of the transmitted messages have 
been received by the one or more other peer nodes; and 

retransmit messages not acknowledged as received by the one or more other peer 
nodes to the one or more other peer node on the communications channel. 
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22. (Original) The peer computing system as recited in claim 1, wherein the peer 
node is further configured to compare elapsed time since the messages were transmitted 
to a timeout limit and, if the elapsed time exceeds the timeout limit, retransmit the 
messages to the other peer node over the communications channel. 

23. (Original) The peer computing system as recited in claim 1, wherein the peer 
node is further configured to: 

receive a request specifying one or more previously transmitted messages for 
retransmission by the peer node; and 

retransmit the specified one or more messages to the other peer node on the 
communications channel in response to the request. 

24. (Previously presented) The peer computing system as recited in claim 23, 
wherein the request specifies a sequence number for each of the one or more specified 
messages, wherein the sequence numbers are for use in ordering the received messages 
on the other peer node. 

25. (Previously presented) A method for providing reliable connections between 
peer nodes coupled to a peer-to-peer network, the method comprising: 

a plurality of peer nodes coupled to the network implementing a peer-to-peer 
environment on the network according to a peer-to-peer platform 
comprising one or more peer-to-peer platform protocols for enabling the 
plurality of peer nodes to discover each other, communicate with each 
other, and share content in the peer-to-peer environment; 
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establishing a communications channel between a network interface of one of the 
plurality of peer nodes and a network interface of another of the plurality 
of peer nodes; 

the peer node transmitting messages to the other peer node over the 
communications channel; 

the peer node receiving acknowledgement that one or more of the transmitted 
messages have been received by the other peer node; and 

the peer node retransmitting messages riot acknowledged as received by the other 
peer node to the other peer node on the communications channel. 

26. (Original) The method as recited in claim 25, wherein, in said transmitting 
messages to the other peer node over the communications channel, the method further 
comprises: 

generating the messages; 4 

buffering the messages, and after a window of N messages has been buffered, 
transmitting the N messages to the other peer node over the 
communications channel, wherein N is an integer greater than one. 

27. (Original) The method as recited in claim 26, further comprising the other 
peer node receiving the transmitted messages, and after receiving M messages, 
transmitting the acknowledgement to the peer node indicating that the M messages have 
been received, wherein M is a positive integer less than or equal to N. 

28. (Original) The method as recited in claim 27, wherein N is a positive even 
integer, and wherein M is equal to N / 2. 
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29. (Original) The method as recited in claim 27, wherein M is less than N. 



30. (Original) The method as recited in claim 29, wherein, in said receiving 
acknowledgement that one or more of the transmitted messages have been received by 
the other peer node, the method further comprises the peer node receiving the 
acknowledgement indicating that the M messages have been received, and wherein the 
method further comprises: 

shifting the window in the buffer by M messages; and 

transmitting the messages in the shifted window to the other peer node over the 
communications channel. 

31. (Original) The method as recited in claim 30, wherein the shifted window 
includes one or more messages previously transmitted to the other peer node and one or 
more messages not previously transmitted to the other peer node. 

32. (Original) The method as recited in claim 26, wherein each of the messages 
includes a sequence number for use in ordering the received messages on the other peer 
node, and wherein the method further comprises: 

the other peer node receiving the transmitted messages; and 

after receiving the first M messages in the sequence of N transmitted messages as 
indicated by the sequence numbers, the other peer node transmitting the 
acknowledgement to the peer node indicating that the first M messages 
have been received, wherein M is a positive integer less than N. 

33. (Original) The method as recited in claim 26, wherein each of the messages 
includes a sequence number for use in ordering the received messages on the other peer 
node, and wherein the method further comprises: 
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the other peer node continuing to receive the transmitted messages until the first 
M messages in the sequence of N transmitted messages as indicated by the 
sequence numbers are received or a timeout limit from the time of initial 
receipt of one of the sequence of N transmitted messages is exceeded, 
wherein M is a positive integer less than N; 

if the first M messages in the sequence of N transmitted messages as indicated by 
the sequence numbers are received, the other peer node transmitting the 
acknowledgement to the peer node indicating that a count of messages 
received in continuous sequence from a first message in the sequence of N 
transmitted messages is M; and 

if the timeout limit is exceeded before the first M messages in the sequence of N 
transmitted messages as indicated by the sequence numbers are received, 
the other peer node transmitting the acknowledgement to the peer node 
indicating the count of messages received in continuous sequence from the 
first message in the sequence of N transmitted messages, wherein the 
count of messages received in continuous sequence is less than M. 

34. (Original) The method as recited in claim 33, wherein, in said receiving 
acknowledgement that one or more of the transmitted messages have been received by 
the other peer node, the method further comprises the peer node receiving the 
acknowledgement indicating that the messages have been received, and wherein the 
method further comprises: 

shifting the window in the buffer by the count of messages received in continuous 
sequence; and 

transmitting the messages in the shifted window to the other peer node over the 
communications channel. 
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35. (Original) The method as recited in claim 25, wherein each of the messages 
includes a sequence number for use in ordering the received messages on the other peer 
node. 

36. (Currently amended) The method as recited in claim [[25]] 27, further 
comprising: 

monitoring reception and retransmission of the messages to determine reliability 
of the communications channel on the network; and 

adjusting the values of M and N according to said reliability of the 
communications channel. 

37. (Original) The method as recited in claim 36, wherein, in said adjusting the 
values of M and N, the method further comprises lowering the values of M and N if said 
reliability of the communications channel is poor. 

38. (Original) The method as recited in claim 36, wherein, in said adjusting the 
values of M and N, the method further comprises raising the values of M and N if said 
reliability of the communications channel is good. 

39. (Original) The method as recited in claim 25, further comprising: 

the other peer node transmitting other messages to the peer node over the 
communications channel; 

the other peer node receiving acknowledgement that one or more of the 
transmitted other messages have been received by the peer node; and 
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the other peer node retransmitting messages not acknowledged as received by the 
peer node to the peer node on the communications channel. 

40. (Original) The method as recited in claim 25, wherein the communications 
channel passes through a relay peer, the method further comprising the relay peer 
receiving the transmitted messages from the peer node and forwarding the messages to 
the other peer node. 

41. (Original) The method as recited in claim 25, wherein the communications 
channel passes through one or more firewalls. 

42. (Original) The method as recited in claim 25, wherein the communications 
channel passes through one or more Network Address Translation (NAT) gateways. 

43. (Original) The method as recited in claim 25, further comprising the peer 
node comparing elapsed time since the messages were transmitted to a timeout limit and, 
if the elapsed time exceeds the timeout limit, retransmitting the messages to the other 
peer node over the communications channel. 

44. (Original) The method as recited in claim 25, further comprising: 

the peer node receiving a request specifying one or more previously transmitted 
messages for retransmission by the peer node; and 

the peer node retransmitting the specified one or more messages to the other peer 
node on the communications channel in response to the request. 

45. (Currently amended) An article of manufacture comprising software 
instructions executable on a peer node to implement: 
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a plurality of p e er nodes coupled to th e n e twork implementing a p ee r to pe e r 
environm e nt on the n e twork according to a poor to peer platform 
comprising on e or mor e poor to p e er platform protocols for enabling the 
plurality of peer nod e s to discov e r each oth e r, communicate with e ach 
other, and share content in th e peer to p ee r e nvironm e nt; 

the peer node establishing a communications channel between a network interface 
of one of the plurality of peer nodes and a network interface of another 
peer node of the a plurality of peer nodes coupled to a network 
implementing a peer-to-peer environment on the network according to a 
peer-to-peer platform comprising one or more peer-to-peer platform 
protocols for enabling the plurality of peer nodes to discover each other, 
communicate with each other, and share content in the peer-to-peer 
environment ; 

the peer node transmitting messages to the other peer node over the 
communications channel; 

the peer node receiving acknowledgement that one or more of the transmitted 
messages have been received by the other peer node; and 

the peer node retransmitting messages not acknowledged as received by the other 
peer node to the other peer node on the communications channel. 

46. (Original) The article of manufacture as recited in claim 45, wherein, in said 
transmitting messages to the other peer node over the communications channel, the J 
software instructions are further executable to implement: 

generating the messages; 
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buffering the messages, and after a window of N messages has been buffered, 
transmitting the N messages to the other peer node over the 
communications channel, wherein N is an integer greater than one. 

47. (Currently amended) The article of manufacture as recited in claim 46, 
wherein the software instructions are further executable to implement the ethef-peer node 
receiving the transmitt e d m e ssag e s, and after r e c e iving M m e ssag e s, transmitting the 
acknowledgement te- from the other peer node indicating that the M messages have been 
received bv the other peer node , wherein M is a positive integer less than or equal to N. 

48. (Original) The article of manufacture as recited in claim 47, wherein N is a 
positive even integer, and wherein M is equal to N / 2. 

49. (Original) The article of manufacture as recited in claim 47, wherein M is less 

than N. 

50. (Currently amended) The article of manufacture as recited in claim 49, 
wherein, in said receiving acknowledgement that one or more of the transmitted 
messages have been received by the other peer node, the software instructions are further 
executable to implement the poor nod e r e c e iving the acknowledgement indicating that th e 
M messages hav e been rec e iv e d, and wh e rein th e softwar e instructions arc furth e r 
executable to implement: 

shifting the window in the buffer by M messages; and 

transmitting the messages in the shifted window to the other peer node over the 
communications channel. 

51. (Original) The article of manufacture as recited in claim 50, wherein the 
shifted window includes one or more messages previously transmitted to the other peer 
node and one or more messages not previously transmitted to the other peer node. 
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52. (Currently amended) The article of manufacture as recited in claim 46, 
wherein each of the messages includes a sequence number for use in ordering the 
received messages on the other peer node, and wherein the software instructions are 
further executable to implement: 

the oth e r p ee r nod e r e c e iving the transmitt e d m e ssages; and 

after receiving the first M m e ssages in the sequ e nce of N transmitt e d messag e s a s 
indicated by th e sequence numbers, the other p ee r nod e transmitting th e 
acknowl e dg e m e nt to th e poor nod e indicating that th e first M messag e s 
have boon rec e iv e d, wh e rein M is a positiv e integ e r l e ss than N 

the peer node receiving acknowledgement from the other peer node indicating 
that the first M messages in the sequence of N transmitted messages as 
indicated by the sequence numbers have been received by the other peer 
node, wherein M is a positive integer less than N . 

53. (Currently amended) The article of manufacture as recited in claim 46, 
wherein each of the messages includes a sequence number for use in ordering the 
received messages on the other peer node, and wherein the software instructions are 
further executable to implement: 

the peer node receiving an acknowledgement from the other peer node indicating: 

the other peer node received M messages in continuous sequence from a 
first message in the sequence of N transmitted message if the other 
peer node continued to receive the transmitted messages until the 
first M messages in the sequence of N transmitted messages were 
received; or 
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the other peer node received less than M messages in continuous sequence 
from the first message in the sequence of N transmitted messages 
if a timeout limit from initial receipt of one of the sequence of N 
transmitted message was exceeded before the first M messages in 
the sequence of N transmitted messages as indicated by the 
sequence numbers was received by the other peer node. 

the other p e er node continuing to receiv e the transmitt e d m e ssages until the first 
M messages in the sequ e nc e of N transmitt e d messages as indicated by the 
sequence numbers are receiv e d or a timeout limit from the time of initial 
receipt of one of the sequence of N transmitted messages is e xc ee d e d, 
wherein M is a positive integer loss than N; 

if the first M messages in the sequence of N transmitted messages as indicated by 
the sequenc e numbers arc received, the other poor node transmitting th e 
acknowledgement to the p ee r node indicating that a count of m e ssag e s 
received in continuous sequ e nce from a first m e ssage in th e sequence of N 
transmitt e d m e ssages is M; and 

if the timeout limit is e xceed e d b e fore the first M messages in th e s e quenc e of N 
transmitted m e ssages as indicated by the sequence numbers arc r e ceiv e d, 
the other pe e r node transmitting the acknowledgem e nt to the peer nod e 
indicating the count of messages received in continuous sequence from th e 
first message in th e s e quence of N transmitted m e ssages, wherein th e 
count of messages received in continuous sequence is loss than M , 

54. (Original) The article of manufacture as recited in claim 53, wherein, in said 
receiving acknowledgement that one or more of the transmitted messages have been 
received by the other peer node, the software instructions are further executable to 
implement the peer node receiving the acknowledgement indicating that the messages 
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have been received, and wherein the software instructions are further executable to 
implement: 

shifting the window in the buffer by the count of messages received in continuous 
sequence; and 

transmitting the messages in the shifted window to the other peer node over the 
communications channel. 

55. (Original) The article of manufacture as recited in claim 45, wherein each of 
the messages includes a sequence number for use in ordering the received messages on 
the other peer node. 

56. (Currently amended) The article of manufacture as recited in claim [[45]] 47, 
further comprising: 

monitoring reception and retransmission of the messages to determine reliability 
of the communications channel on the network; and 

adjusting the values of M and N according to said reliability of the 
communications channel. 

57. (Original) The article of manufacture as recited in claim 56, wherein, in said 
adjusting the values of M and N, the software instructions are further executable to 
implement lowering the values of M and N if said reliability of the communications 
channel is poor. 

58. (Original) The article of manufacture as recited in claim 56, wherein, in said 
adjusting the values of M and N, the software instructions are further executable to 
implement raising the values of M . and N if said reliability of the communications 
channel is good. 
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59. (Currently amended) The article of manufacture as recited in claim 45, 
wherein the software instructions are further executable to implement: 

the ether peer node transmitting receiving other messages te from the other p eer 
node over the communications channel; 

the oth e r peer node r e c e iving sending acknowledgement to the other peer node 
that one or more of the transmitted other messages have been received by 
the peer node; and 

the oth e r peer node receiving retransmitting retransmitted messages not 
acknowledged as received by the peer node to the p ee r nod e on the 
communications channel. 

60. (Currently amended) The article of manufacture as recited in claim 45, 
wh e rein the communications chann e l passes through a relay p ee r, wherein the software 
instructions are further executable to implement: 

configuring the peer node as a relay peer, wherein a communications channel 
between a third peer node of the plurality of peer nodes and the other peer 
node passes through the peer node; 

the relay-peer node receiving the transmitt e d messages transmitted from the third 
peer node to the other peer node; and 

forwarding the messages to the other peer node. 

61. (Original) The article of manufacture as recited in claim 45, wherein the 
communications channel passes through one or more firewalls. 
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62. (Original) The article of manufacture as recited in claim 45, wherein the 
communications channel passes through one or more Network Address Translation 
(NAT) gateways. 

63. (Original) The article of manufacture as recited in claim 45, wherein the 
software instructions are further executable to implement the peer node comparing 
elapsed time since the messages were transmitted to a timeout limit and, if the elapsed 
time exceeds the timeout limit, retransmitting the messages to the other peer node over 
the communications channel. 

64. (Original) The article of manufacture as recited in claim 45, further 
comprising: 

the peer node receiving a request specifying one or more of the transmitted 
messages for retransmission by the peer node; and 

the peer node retransmitting the specified one or more messages to the other peer 
node on the communications channel in response to the request. 
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